<template>
    <div>
        <action-container>
            <page-header title="修改密码" content="定期修改密码可以提高帐号安全性噢~" />
            <el-row>
                <el-col :md="24" :lg="12">
                    <el-form ref="form" :model="form" :rules="rules" label-width="120px">
                        <el-form-item label="原密码" prop="password">
                            <el-input v-model="form.password" type="password" placeholder="请输入原密码" />
                        </el-form-item>
                        <el-form-item label="新密码" prop="newpassword">
                            <el-input v-model="form.newpassword" type="password" placeholder="请输入原密码" />
                        </el-form-item>
                        <el-form-item label="确认新密码" prop="checkpassword">
                            <el-input v-model="form.checkpassword" type="password" placeholder="请输入原密码" />
                        </el-form-item>
                    </el-form>
                </el-col>
            </el-row>
            <template #action>
                <el-button type="primary" size="large" @click="onSubmit">提交</el-button>
            </template>
        </action-container>
    </div>
</template>

<script setup name="PersonalEditPassword">
const route = useRoute(), router = useRouter()
const { proxy } = getCurrentInstance()

import { useUserStore } from '@/store/modules/user'
const userStore = useUserStore()

const validatePassword = (rule, value, callback) => {
    if (value !== form.value.newpassword) {
        callback(new Error('请确认新密码'))
    } else {
        callback()
    }
}

const form = ref({
    password: '',
    newpassword: '',
    checkpassword: ''
})

const rules = ref({
    password: [
        { required: true, message: '请输入原密码', trigger: 'blur' }
    ],
    newpassword: [
        { required: true, message: '请输入新密码', trigger: 'blur' },
        { min: 6, max: 18, trigger: 'blur', message: '密码长度为6到18位' }
    ],
    checkpassword: [
        { required: true, message: '请输入新密码', trigger: 'blur' },
        { validator: validatePassword }
    ]
})

function onSubmit() {
    proxy.$refs['formRef'].validate(valid => {
        if (valid) {
            userStore.editPassword(form.value).then(() => {
                proxy.$message({
                    type: 'success',
                    message: '模拟修改成功，请重新登录'
                })
                userStore.logout().then(() => {
                    router.push({
                        name: 'login',
                        query: {
                            redirect: route.fullPath
                        }
                    })
                })
            }).catch(() => {})
        }
    })
}
</script>
